home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 15
/
Aminet 15 - Nov 1996.iso
/
Aminet
/
dev
/
gcc
/
ixemsdk.lha
/
man
/
cat3
/
getservent.0
< prev
next >
Wrap
Text File
|
1996-09-02
|
4KB
|
87 lines
GETSERVENT(3) UNIX Programmer's Manual GETSERVENT(3)
NNAAMMEE
ggeettsseerrvveenntt, ggeettsseerrvvbbyyppoorrtt, ggeettsseerrvvbbyynnaammee, sseettsseerrvveenntt, eennddsseerrvveenntt - get
service entry
SSYYNNOOPPSSIISS
##iinncclluuddee <<nneettddbb..hh>>
_s_t_r_u_c_t _s_e_r_v_e_n_t _*
ggeettsseerrvveenntt()
_s_t_r_u_c_t _s_e_r_v_e_n_t _*
ggeettsseerrvvbbyynnaammee(_c_h_a_r _*_n_a_m_e, _c_h_a_r _*_p_r_o_t_o)
_s_t_r_u_c_t _s_e_r_v_e_n_t _*
ggeettsseerrvvbbyyppoorrtt(_i_n_t _p_o_r_t, _p_r_o_t_o)
_v_o_i_d
sseettsseerrvveenntt(_i_n_t _s_t_a_y_o_p_e_n)
_v_o_i_d
eennddsseerrvveenntt(_v_o_i_d)
DDEESSCCRRIIPPTTIIOONN
The ggeettsseerrvveenntt(), ggeettsseerrvvbbyynnaammee(), and ggeettsseerrvvbbyyppoorrtt() functions each re-
turn a pointer to an object with the following structure containing the
broken-out fields of a line in the network services data base,
_/_e_t_c_/_s_e_r_v_i_c_e_s.
struct servent {
char *s_name; /* official name of service */
char **s_aliases; /* alias list */
int s_port; /* port service resides at */
char *s_proto; /* protocol to use */
};
The members of this structure are:
_s___n_a_m_e The official name of the service.
_s___a_l_i_a_s_e_s A zero terminated list of alternate names for the service.
_s___p_o_r_t The port number at which the service resides. Port numbers
are returned in network byte order.
_s___p_r_o_t_o The name of the protocol to use when contacting the service.
The ggeettsseerrvveenntt() function reads the next line of the file, opening the
file if necessary.
The sseettsseerrvveenntt() function opens and rewinds the file. If the _s_t_a_y_o_p_e_n
flag is non-zero, the net data base will not be closed after each call to
ggeettsseerrvvbbyynnaammee() or ggeettsseerrvvbbyyppoorrtt().
The eennddsseerrvveenntt() function closes the file.
The ggeettsseerrvvbbyynnaammee() and ggeettsseerrvvbbyyppoorrtt() functions sequentially search
from the beginning of the file until a matching protocol name or port
number is found, or until EOF is encountered. If a protocol name is also
supplied (non- NULL), searches must also match the protocol.
FFIILLEESS
/etc/services
DDIIAAGGNNOOSSTTIICCSS
Null pointer (0) returned on EOF or error.
SSEEEE AALLSSOO
getprotoent(3), services(5)
HHIISSTTOORRYY
The ggeettsseerrvveenntt(), ggeettsseerrvvbbyyppoorrtt(), ggeettsseerrvvbbyynnaammee(), sseettsseerrvveenntt(), and
eennddsseerrvveenntt() functions appeared in 4.2BSD.
BBUUGGSS
These functions use static data storage; if the data is needed for future
use, it should be copied before any subsequent calls overwrite it. Ex-
pecting port numbers to fit in a 32 bit quantity is probably naive.
4.2 Berkeley Distribution January 12, 1994 2